1 CLAIMS LISTING 

2 

3 1 . (Original) A method of asynchronous data replication over a network, 

4 wherein one or more applications send write commands to a primary host, comprising: 

5 at the primary host: 

6 acknowledging each write command before transmitting the write command to a 

7 secondary host; 

8 assigning a data set ID to each write command; 

9 transmitting each write command before the application has sent all of the write 

1 0 commands of the data set to the primary host; 

1 1 assigning the data set ID to a sync command; 

12 transmitting the sync command, wherein the write commands and the sync 

1 3 command define a data set; 

1 4 at the secondary host: 

1 5 receiving the write commands and sync command out of order; and 

16 writing the data set to a storage coupled to the secondary host. 
17 

1 8 2. (Original) The method of claim 1 , further comprising tracking the receipt of 

1 g write and sync commands at the secondary host. 

20 

21 3. (Original) The method of claim 2, further comprising assigning a unique 

22 sequence number for each write command and another sequence number to the sync 

23 command at the primary host. 

24 

25 4. (Original) The method of claim 3, wherein tracking the receipt of write and 

2Q sync commands includes setting bits in an identifier bitmap corresponding to the data 

2 7 set at the secondary host. 

28 

5. (Original) The method of claim 1 , further comprising writing the blocks to 
a secondary target VLUN and acknowledging the write and sync commands before 

ou 

receipt of the data set at secondary host. 

3 



1 

2 6. (Original) The method of claim 1 , further comprising storing multiple 

3 versions of one of the blocks at the primary host while waiting for an acknowledgement 

4 from the secondary host. 
5 

6 7. (Original) The method of claim 4, further comprising using the identifier 

7 bitmap to determine receipt of the data set at the secondary host. 

8 

g 8. (Original) The method of claim 3, further comprising updating a data 

1 o structure at the secondary host to track the blocks in the secondary target VLUN. 

11 

12 9 - (Original) The method of claim 8, wherein updating the data structure at 

-1 3 the secondary host includes setting bits in a bitmap and updating a log file. 

14 

1 5 10. (Original) The method of claim 1 , further comprising writing the blocks to 

16 a memory buffer at the secondary host and acknowledging the write and sync 

1 7 commands at the secondary host before receipt of the data set. 

18 

1 g 11. (Original) The method of claim 1 , wherein the step of receiving at the 

2Q secondary host includes receiving write commands belonging to a plurality of data sets 
that are overlapping with respect to each other. 
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12. (Original) The method of claim 1 , further comprising receiving a second 
data set at the secondary host, wherein the step of receiving write commands for the 
second data set precedes receiving write commands of the data set. 

1 3. (Original) The method of claim 1 , further comprising storing the data sets 
in a plurality of data structures. 

14. (Original) The method of claim 1 , further comprising transmitting the write 
and sync commands on the network using the Fibre channel protocol. 
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1 1 5. (Original) The method of claim 1 , further comprising transmitting the write 

2 and sync commands on the network using the iSCSI protocol. 
3 

4 16. (Original) The method of claim 1 , wherein the step of writing includes the 

5 secondary host writing the blocks of the data set to the secondary source VLUN. 
6 

7 1 7. (Original) The method of claim 1 , wherein the data set contains one or 

8 more file system transactions. 

9 

10 18 - (Original) A system of asynchronous data replication, comprising: 

1 -j a primary host asynchronously transmitting write commands and a sync 

12 command, wherein each write command has a data set ID and each sync command 

1 3 has a data set ID; and 

14 a secondary host, coupled to the primary host, tracking receipt of write and sync 

1 5 commands and after receipt of the write and sync commands of the data set ID writing 

16 the write commands to a storage coupled to the secondary host. 

17 

^ 8 19. (Original) The system of claim 1 8, further comprising a data structure at 

^ g the secondary host for tracking receipt of write and sync commands. 
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20. (Original) The system of claim 19, wherein the data structure includes a 
flag to indicate when the write commands and the sync command of a data set are 
received at the secondary host. 

21 . (Original) The system of claim 20, wherein the secondary host writes the 
data set to storage after a temporary failure of the secondary host if the flag indicates 
that the write and sync commands of the data set were received. 

22. (Original) A system of asynchronous data replication, comprising: 

a primary host asynchronously transmitting write and sync commands for a first 
data set and a second data set; and 
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1 a secondary host, coupled to the primary host, receiving the write and sync 

2 commands and writing the data set to storage, wherein the primary host transmits write 

3 and sync commands for the second data set before the secondary host acknowledges 

4 the first data set was written to storage. 
5 

6 23. (Original) A system of asynchronous data replication, comprising: 

7 a primary host asynchronously transmitting write commands and the blocks 

8 without waiting to complete a data set followed by a sync command; and 

g a secondary host coupled to the network receiving the write commands, the 

I o blocks, and the sync command in any order, wherein the secondary host writes the data 

I I set to storage coupled to the secondary host. 

12 

-1 3 24. (Original) A system of asynchronous data replication, comprising: 

14 a primary host receiving write commands from an application, generating sync 

-1 5 commands, and transmitting the write and sync commands over a network 

1 6 asynchronously and independently from one or more data sets; and 

^ j a secondary host, coupled to the network, receiving the write and sync 

1 g commands out of order and writing the data sets in order to storage coupled to the 

^ secondary host. 

20 

21 25. (Original) A method of data replication, comprising the steps of: 

transmitting a data set from a primary host to a secondary host wherein the 
secondary host includes a data structure with a complete flag; 

writing the data set to a target VLUN at the secondary host; 
setting the complete flag = yes once the data set is written to the target VLUN at 
the secondary host; and 

writing the data set to a source VLUN at the secondary host. 
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1 26. (Original) A method of data replication comprising the steps of: 

2 transmitting a data set from a primary host to a secondary host wherein the 

3 secondary host includes a data structure with a complete flag; 

4 writing the data set to a target VLUN at the secondary host; 

5 setting the complete flag = yes once the data set is written to the target VLUN at 

6 the secondary host; 

7 resuming operation of the secondary host after a failure; and 

8 writing the data set to a source VLUN at the secondary host. 
9 

10 27. (Original) A method of data replication comprising the steps of: 

1 1 transmitting a data set from a primary host to a secondary host wherein the 
-j 2 secondary host includes a data structure with a complete flag; 

1 3 writing part of the data set to a target VLUN at the secondary host; 

14 resuming operation of the secondary host after a failure; 

1 5 erasing the part of data set written to the target VLUN at the secondary host; 

1 6 retransmitting the data set from the primary host to the secondary host; 

1 7 writing the data set to the target VLUN at the secondary host; 

1g setting the complete flag = yes once the data set is written to the target VLUN at 

^ the secondary host; and 

2Q writing the data set to a source VLUN at the secondary host. 
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